<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8"/>
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
        <title>AJ Utils-Types 教程</title>
        <meta name="description" content="Small Java utilities with many useful functions.  Types 类提供了处理 Java 泛型类型信息的实用方法" />
        <meta name="keywords" content="AJ Utils, ajaxjs, ajaxjs framework, java utilities, tools, helper, 泛型,类型转换,Java" />
        <meta name="viewport" content="width=device-width, initial-scale=1"/>
        <link rel="preconnect" href="https://fonts.googleapis.com" />
        <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
        <link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@200..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap&family=Noto+Sans+SC:wght@100..900&display=swap" />
        <link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@100..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap" /> 
        <link rel="stylesheet" href="https://framework.ajaxjs.com/static/new-ui/css/common.css" />
        <link rel="stylesheet" href="https://iam.ajaxjs.com/asset/main.css"/>
        <link rel="icon" type="image/x-icon" href="https://framework.ajaxjs.com/aj-logo/logo.ico"/>
        <script src="https://framework.ajaxjs.com/static/aj-docs/common.js"></script>
        <script>
            var _hmt = _hmt || [];
            (function() {
              var hm = document.createElement("script");
              hm.src = "https://hm.baidu.com/hm.js?208c5aea11c52991bd1c3283e62ad0ce";
              var s = document.getElementsByTagName("script")[0];
              s.parentNode.insertBefore(hm, s);
            })();
        </script>
    </head>
    <body>
        <nav>
            <div>
                <div class="links">
                    <a href="/cn">🏠 首页</a>
                    | ⚙️ 源码:
                    <a target="_blank" href="https://github.com/lightweight-component/aj-util">Github</a>/<a target="_blank" href="https://gitcode.com/lightweight-component/aj-util">Gitcode</a>
                  
                    | 🚀<a href="">英语版本</a>
                </div>
                <h1>
                    <img src="https://framework.ajaxjs.com/aj-logo/logo.png" style="vertical-align: middle;height: 45px;margin-bottom: 6px;" />
                    AJ Utils
                </h1>
                <h3>小型、干净、简单的 Java 工具库
                </h3>
            </div>
        </nav>
        <div>
            <menu>
                
                <ul>
                    <li class="selected">
                        <a href="/cn">首页</a>
                    </li>
                </ul>
                <h3>Common 常用模块</h3>
                <ul>
                    <li><a href="/common/JsonUtil-cn/">JsonUtil</a></li>
                    <li><a href="/common/Base64Helper-cn/">Base64Helper</a></li>
                    <li><a href="/common/ConvertBasicValue-cn/">ConvertBasicValue</a></li>
                    <li><a href="/common/MessageDigestHelper-cn/">HashHelper</a></li>
                    <li><a href="/common/MapTool-cn/">MapTool</a></li>
                    <li><a href="/common/ObjectHelper-cn/">ObjectHelper</a></li>
                    <li><a href="/common/RandomTools-cn/">RandomTools</a></li>
                    <li><a href="/common/RegExpUtils-cn/">RegExpUtils</a></li>
                    <li><a href="/common/StrUtil-cn/">StrUtil</a></li>
                    <li><a href="/common/BoxLogger-cn/">BoxLogger</a></li>
                    <li><a href="/common/BytesHelper-cn/">BytesHelper</a></li>
                    <li><a href="/common/EncodeTools-cn/">UrlEncode</a></li>
                    <li><a href="/common/XmlHelper-cn/">XmlHelper</a></li>
                    <li><a href="/common/WebUtils-cn/">WebUtils</a></li>
                </ul>
                <h3>Date 日期处理</h3>
                <ul>
                    <li><a href="/date/intro-cn/">简介</a></li>
                    <li><a href="/date/convert-cn/">万能日期类型转换</a></li>
                    <li><a href="/date/formatter-cn/">日期格式化</a></li>
                </ul>
                <h3>Reflection 反射</h3>
                <ul>
                    <li><a href="/reflect/Methods-cn/">Methods</a></li>
                    <li><a href="/reflect/Types-cn/">Types</a></li>
                    <li><a href="/reflect/Clazz-cn/">Clazz</a></li>
                </ul>

                <h3>Input/Output 输入/输出</h3>
                <ul>
                    <li><a href="/io/FileHelper-cn/">FileHelper</a></li>
                    <li><a href="/io/Resources-cn/">Resources</a></li>
                    <li><a href="/io/StreamHelper-cn/">DataReader/DataWriter</a></li>
                    <li><a href="/io/ZipHelper-cn/">ZipHelper</a></li>
                </ul>

                <h3>HTTP 请求</h3>
                <ul>
                    <li><a href="/http_request/Get-cn">HTTP 请求</a></li>
                     <li><a href="/http_request/advanced-usage-cn/">高级用法</a></li>
                    <li><a href="/http_request/Base-cn/">Base</a></li>
                </ul>

                <h3>加密/解密</h3>
                <ul>
                    <li><a href="/cryptography/intro-cn/">简介</a></li>
                    <li><a href="/cryptography/flow-cn/">基本流程</a></li>
                    <li><a href="/cryptography/AesCrypto-cn/">AES/DES 加密解密</a></li>
                    <li><a href="/cryptography/RsaCrypto-cn/">RSA 加密解密</a></li>
                </ul>
            </menu>
            <article class="aj-text chinese">
                <h1>Types</h1>
<p><code>Types</code> 类提供了检索泛型类型信息、转换类型以及处理参数化类型的方法。这些方法有助于在运行时高效、方便地操作 Java 类型。</p>
<h2>方法</h2>
<h3>1. <code>getActualType(Type type)</code></h3>
<p>检索参数化类型的实际类型参数。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>type</code>: 要从中检索实际类型参数的类型。</li>
</ul>
</li>
<li><strong>返回值:</strong> 表示实际类型参数的 <code>Type</code> 数组，如果输入类型不是参数化类型，则返回 <code>null</code>。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Type type = new ParameterizedType() {
    @Override
    public Type[] getActualTypeArguments() {
        return new Type[]{String.class};
    }

    @Override
    public Type getRawType() {
        return List.class;
    }

    @Override
    public Type getOwnerType() {
        return null;
    }
};
Type[] actualType = Types.getActualType(type);
// actualType 将包含 String.class
</code></pre>
<h3>2. <code>getGenericReturnType(Method method)</code></h3>
<p>检索方法返回类型的实际类型参数。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>method</code>: 要从中检索返回类型的类型。</li>
</ul>
</li>
<li><strong>返回值:</strong> 表示返回类型实际类型参数的 <code>Type</code> 数组。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Method method = TestTypes.class.getMethods()[0];
Type[] actualType = Types.getGenericReturnType(method);
// actualType 将包含方法的泛型返回类型
</code></pre>
<h3>3. <code>getGenericFirstReturnType(Method method)</code></h3>
<p>检索方法返回类型的第一个实际类型参数并将其转换为 <code>Class</code>。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>method</code>: 要从中检索返回类型的类型。</li>
</ul>
</li>
<li><strong>返回值:</strong> 返回类型的第一个实际类型参数作为 <code>Class</code>，如果返回类型不是参数化的，则返回 <code>null</code>。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Method method = TestTypes.class.getMethods()[0];
Class&lt;?&gt; actualType = Types.getGenericFirstReturnType(method);
// actualType 将是方法的第一个泛型返回类型，作为 Class
</code></pre>
<h3>4. <code>getActualType(Class&lt;?&gt; clz)</code></h3>
<p>检索类的超类的实际类型参数。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>clz</code>: 要从中检索实际类型参数的类。</li>
</ul>
</li>
<li><strong>返回值:</strong> 表示类的超类的实际类型参数的 <code>Type</code> 数组。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Type[] actualType = Types.getActualType(ArrayList.class);
// actualType 将包含 ArrayList 超类的泛型类型参数
</code></pre>
<h3>5. <code>getActualClass(Class&lt;?&gt; clz)</code></h3>
<p>检索类的超类的第一个实际类型参数并将其转换为 <code>Class</code>。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>clz</code>: 要从中检索实际类型参数的类。</li>
</ul>
</li>
<li><strong>返回值:</strong> 超类的第一个实际类型参数作为 <code>Class</code>。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Class&lt;?&gt; actualClass = Types.getActualClass(ArrayList.class);
// actualClass 将是 ArrayList 超类的第一个泛型类型参数，作为 Class
</code></pre>
<h3>6. <code>type2class(Type type)</code></h3>
<p>将 <code>Type</code> 转换为 <code>Class</code>。</p>
<ul>
<li><strong>参数说明：</strong>
<ul>
<li><code>type</code>: 要转换的 <code>Type</code>。</li>
</ul>
</li>
<li><strong>返回值:</strong> <code>Type</code> 的 <code>Class</code> 表示，如果 <code>Type</code> 不是 <code>Class</code>，则返回 <code>null</code>。</li>
</ul>
<p><strong>示例:</strong></p>
<pre><code class="language-java">Type type = String.class;
Class&lt;?&gt; actualClass = Types.type2class(type);
// actualClass 将是 String.class
</code></pre>

            </article>
        </div>

       <footer>
            AJ-Util，开源框架 <a href="https://framework.ajaxjs.com" target="_blank">AJ-Framework</a> 的一部分。联系方式：
            frank@ajaxjs.com，<a href="https://blog.csdn.net/zhangxin09" target="_blank">作者博客</a>
            <br />
            <br />
            Copyright © 2025 Frank Cheung. All rights reserved.
        </footer>
    </body>
</html>